package com.suxin.shiro.main;

import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.mgt.DefaultSecurityManager;
import org.apache.shiro.realm.text.IniRealm;
import org.apache.shiro.subject.Subject;

/**
 * @author Tang
 * @classname ShiroTest
 * @description [  ]
 * @date 2021/3/18 9:13
 */
public class ShiroTest {

    public static void main(String[] args) {
        // 创建一个安全管理器
        DefaultSecurityManager securityManager = new DefaultSecurityManager();
        // 给安全管理器设置数据源
        securityManager.setRealm(new IniRealm("classpath:shiro.ini"));

        // 全局安全工具类 设置安全管理器
        SecurityUtils.setSecurityManager(securityManager);
        // 获取一个主体
        Subject subject = SecurityUtils.getSubject();

        // 创建一个token去登录
        UsernamePasswordToken token = new UsernamePasswordToken("zhang","123");
        try {
            System.out.println("是否认证：" + subject.isAuthenticated());
            subject.login(token);
            System.out.println("是否认证：" + subject.isAuthenticated());
        } catch (Exception e) {
            System.err.println("认证失败....");
        }
    }

}